//导入 express 
const express = require('express')
//创建服务器的实例对象
const app = express()
//导入 joi
const joi = require('joi')


//导入并配置 cors 中间件
const cors = require('cors')
app.use(cors())

//配置表单数据的中间件,注意这个中间件只能解析 application/x-www-form-urlencoded格式的表单数据
app.use(express.urlencoded({extended:false}))

//一定要在路由之前，封装 res.cc函数
app.use((req,res,next) => {
    // status 默认值为1，表示失败的情况
    // err 的值，可能是一个错误对象，也可能是一个错误的描述字符串
    res.cc = function(err,status = 1) {
      res.send({
        status,
        message: err instanceof Error ? err.message : err,
      })
    }
    next()
})

// 一定要在路由之前配置解析 Token 的中间件
const expressJWT = require('express-jwt')
const config = require('./config')

app.use(expressJWT({secret: config.jwtSecretKey,algorithms: ["HS256"]}).unless({path: [/^\/api\//]}))

//导入并使用用户路由模块
const userRouter = require('./router/user')
app.use('/api',userRouter)
//导入并使用用户信息的路由模块
const userinfoRouter = require('./router/userinfo')
app.use('/my',userinfoRouter)
//导入并使用文章分类的路由模块
const artcateRouter = require('./router/artcate')
app.use('/my/article',artcateRouter)
//导入并使用文章发布路由模块
const articleRouter = require('./router/article')
app.use('/my/article',articleRouter)
// 托管静态资源文件
app.use('/uploads', express.static('./uploads'))


//定义错误级别的中间件
app.use((err,req,res,next) => {
  //验证失败
  if(err instanceof joi.ValidationError) return res.cc(err)
  //身份认证失败的错误
  if(err.name === 'UnauthorizedError') return res.cc('身份认证失败！')
    //未知的错误
    res.cc(err)
})

//启动服务器
app.listen(3000,() =>{
    console.log('api server running at http://127.0.0.1:3000')
})